#!/bin/bash

CLUSTERNAME=$(params.cluster-name)
INFRAENV=$(params.infraenv)
NAMESPACE=$(params.infraenv)
TIMEOUT=3600  # 60 minutes timeout
SLEEP_INTERVAL=600  # Check every 10 minutes

# Check if the Managed Cluster is joined and available from the Hub
check_hub_status() {
    joined_status=$(oc get managedcluster ${CLUSTERNAME} -n ${NAMESPACE} -o jsonpath='{.status.conditions[?(@.type=="ManagedClusterJoined")].status}')
    available_status=$(oc get managedcluster ${CLUSTERNAME} -n ${NAMESPACE} -o jsonpath='{.status.conditions[?(@.type=="ManagedClusterConditionAvailable")].status}')
    
    if [[ "${joined_status}" == "True" && "${available_status}" == "True" ]]; then
        echo "Managed cluster ${CLUSTERNAME} is joined and available in ACM Hub."
        return 0  # This tells the calling function that the cluster is ready
    else
        echo "Managed cluster ${CLUSTERNAME} is not fully ready in ACM Hub."
        return 1  # This tells the calling function that the cluster is not ready
    fi
}

# Fetch the managed cluster's kubeconfig
oc get secret ${CLUSTERNAME}-admin-kubeconfig -n ${NAMESPACE} -o jsonpath='{.data.kubeconfig}' | base64 -d > /tmp/${CLUSTERNAME}-kubeconfig

# Function to check if all nodes are in 'Ready' state in the spoke cluster
check_spoke_nodes_ready() {
    local not_ready_count
    not_ready_count=$(oc get nodes --no-headers --kubeconfig /tmp/${CLUSTERNAME}-kubeconfig | grep -v ' Ready' | wc -l)
    echo "$not_ready_count"
}

# Function to check if all cluster operators are in 'Available' state
check_spoke_co_ready() {
    local degraded_count
    degraded_count=$(oc get co --no-headers --kubeconfig /tmp/${CLUSTERNAME}-kubeconfig | grep -v 'Available=True' | grep -E 'Degraded=True|Progressing=True|Available=False' | wc -l)
    echo "$degraded_count"
}

# Start timer
start_time=$(date +%s)

# Loop until all checks pass or timeout is reached
while true; do
    # Step 1: Check hub status
    if check_hub_status; then
        # Step 2: Check if all nodes in the spoke are ready
        not_ready_nodes=$(check_spoke_nodes_ready)

        if [[ "$not_ready_nodes" -eq 0 ]]; then
            echo "All nodes in ${CLUSTERNAME} are in 'Ready' state."
        else
            echo "Waiting for all nodes in ${CLUSTERNAME} to be 'Ready'... ($not_ready_nodes not ready)"
            sleep $SLEEP_INTERVAL
            continue
        fi

        # Step 3: Check if all cluster operators in the spoke are ready
        not_ready_operators=$(check_spoke_co_ready)

        if [[ "$not_ready_operators" -eq 0 ]]; then
            echo "All cluster operators in ${CLUSTERNAME} are 'Available'."
            break
        else
            echo "Waiting for all cluster operators in ${CLUSTERNAME} to be 'Available'... ($not_ready_operators not available)"
            sleep $SLEEP_INTERVAL
            continue
        fi
    else
        sleep $SLEEP_INTERVAL
        continue
    fi

    # Check for timeout
    current_time=$(date +%s)
    elapsed_time=$((current_time - start_time))
    if [[ $elapsed_time -gt $TIMEOUT ]]; then
        echo "Error: Timeout reached. Cluster ${CLUSTERNAME} is not fully ready."
        exit 1
    fi
done

echo "Cluster readiness check complete."
exit 0
